# Boolean Arithmetic



Building a Modern Computer From First Principles
www.nand2tetris.org

# Counting systems

| quantity | decimal | binary | 3-bit register |
|----------|---------|--------|----------------|
|          | 0       | 0      | 000            |
| *        | 1       | 1      | 001            |
| **       | 2       | 10     | 010            |
| ***      | 3       | 11     | 011            |
| ***      | 4       | 100    | 100            |
| ****     | 5       | 101    | 101            |
| ****     | 6       | 110    | 110            |
| *****    | 7       | 111    | 111            |
| *****    | 8       | 1000   | overflow       |
| ******   | 9       | 1001   | overflow       |
| *****    | 10      | 1010   | overflow       |

#### Rationale

$$(9038)_{ten} = 9 \cdot 10^3 + 0 \cdot 10^2 + 3 \cdot 10^1 + 8 \cdot 10^0 = 9038$$

$$(10011)_{two} = 1 \cdot 2^4 + 0 \cdot 2^3 + 0 \cdot 2^2 + 1 \cdot 2^1 + 1 \cdot 2^0 = 19$$

$$(x_n x_{n-1} ... x_0)_b = \sum_{i=0}^n x_i \cdot b^i$$

## Binary addition

#### Assuming a 4-bit system:





- Algorithm: exactly the same as in decimal addition
- Overflow (MSB carry) has to be dealt with.

#### Representing negative numbers (4-bit system)

| 0 | 0000 |      |    |
|---|------|------|----|
| 1 | 0001 | 1111 | -1 |
| 2 | 0010 | 1110 | -2 |
| 3 | 0011 | 1101 | -3 |
| 4 | 0100 | 1100 | -4 |
| 5 | 0101 | 1011 | -5 |
| 6 | 0110 | 1010 | -6 |
| 7 | 0111 | 1001 | -7 |
|   |      | 1000 | -8 |
|   |      |      |    |

- The codes of all positive numbers begin with a "O"
- The codes of all negative numbers begin with a "1"
- To convert a number: leave all trailing 0's and first 1 intact, and flip all the remaining bits

Example: 
$$2-5=2+(-5)=0010$$

$$+1011$$

$$-1101=-3$$

### Building an Adder chip



- Adder: a chip designed to add two integers
- Proposed implementation:

Half adder: designed to add 2 bits

• Full adder: designed to add 3 bits

Adder: designed to add two n-bit numbers.

### Half adder (designed to add 2 bits)

| а | b | sum carry |
|---|---|-----------|
| 0 | 0 | 0 0       |
| 0 | 1 | 1 0       |
| 1 | 0 | 1 0       |
| 1 | 1 | 0 1       |



<u>Implementation</u>: based on two gates that you've seen before.

### Full adder (designed to add 3 bits)

| а | b | С | sum carry |   |
|---|---|---|-----------|---|
|   |   |   |           |   |
| 0 | 0 | 0 | 0         | 0 |
| 0 | 0 | 1 | 1         | 0 |
| 0 | 1 | 0 | 1         | 0 |
| 0 | 1 | 1 | 0         | 1 |
| 1 | 0 | 0 | 1         | 0 |
| 1 | 0 | 1 | 0         | 1 |
| 1 | 1 | 0 | 0         | 1 |
| 1 | 1 | 1 | 1         | 1 |



Implementation: can be based on half-adder gates.

#### *n*-bit Adder (designed to add two 16-bit numbers)





Implementation: array of full-adder gates.

#### The ALU (of the Hack platform)





# ALU logic (Hack platform)

|                      | These bits instruct how to pre-set the x input            |                      | These bits instruct how to The pre-set the y input bet |                                          | This bit inst. how to post-set out | Resulting<br>ALU output |
|----------------------|-----------------------------------------------------------|----------------------|--------------------------------------------------------|------------------------------------------|------------------------------------|-------------------------|
| zx                   | nx                                                        | zy                   | ny                                                     | f                                        | no                                 | out=                    |
| if zx<br>then<br>x=0 | if nx<br>then<br>x=!x                                     | if zy<br>then<br>y=0 | if ny<br>then<br>y=!y                                  | if f then<br>out=x+y else<br>out=x And y | if no<br>then<br>out=!out          | f(x,y)=                 |
| 1                    | 0                                                         | 1                    | 0                                                      | 1                                        | 0                                  | 0                       |
| 1                    | 1                                                         | 1                    | 1                                                      | 1                                        | 1                                  | 1                       |
| 1                    | 1                                                         | 1                    | 0                                                      | 1                                        | 0                                  | -1                      |
| 0                    | ٥                                                         | 1                    | 1                                                      | 0                                        | Λ                                  | х                       |
| 1                    |                                                           |                      |                                                        |                                          | У                                  |                         |
| 0                    | o <u>Implementation</u> : build a logic gate architecture |                      |                                                        |                                          |                                    | !x                      |
| 1                    | that "executes" the control bit "instructions":           |                      |                                                        |                                          |                                    | ! y                     |
| 0                    | o if $zx==1$ then set x to 0 (bit-wise), etc.             |                      |                                                        |                                          |                                    | -x                      |
| 1                    |                                                           | •                    |                                                        |                                          |                                    | -y                      |
| 0                    | 1                                                         | 1                    | 1                                                      | 1                                        | 1                                  | x+1                     |
| 1                    | 1                                                         | 0                    | 1                                                      | 1                                        | 1                                  | y+1                     |
| 0                    | 0                                                         | 1                    | 1                                                      | 1                                        | 0                                  | x-1                     |
| 1                    | 1                                                         | 0                    | 0                                                      | 1                                        | 0                                  | y-1                     |
| 0                    | 0                                                         | 0                    | 0                                                      | 1                                        | 0                                  | x+y                     |
| 0                    | 1                                                         | 0                    | 0                                                      | 1                                        | 1                                  | х-у                     |
| 0                    | 0                                                         | 0                    | 1                                                      | 1                                        | 1                                  | у-х                     |
| 0                    | 0                                                         | 0                    | 0                                                      | 0                                        | 0                                  | х&У                     |
| 0                    | 1                                                         | 0                    | 1                                                      | 0                                        | 1                                  | x   y                   |

#### The ALU in the CPU context (a sneak preview of the Hack platform)



### Perspective

- Combinational logic
- Our adder design is very basic: no parallelism
- It pays to optimize adders
- Our ALU is also very basic: no multiplication, no division
- Where is the seat of more advanced math operations? a typical hardware/software tradeoff.

#### Historical end-note: Leibnitz (1646-1716)

- "The binary system may be used in place of the decimal system; express all numbers by unity and by nothing"
- 1679: built a mechanical calculator (+, -, \*, /)



- CHALLENGE: "All who are occupied with the reading or writing of scientific literature have assuredly very often felt the want of a common scientific language, and regretted the great loss of time and trouble caused by the multiplicity of languages employed in scientific literature:
- SOLUTION: "Characteristica Universalis": a universal, formal, and decidable language of reasoning
- The dream's end: Turing and Gödel in 1930's.





Leibniz's medallion for the Duke of Brunswick